/* 
  处理动画时 display:none 无效：使用opacity: 0;pointer-events: none;效果等同display:none;同时不会阻碍元素
  注意 css 动画在开关时的使用，以及对padding等属性的影响
 */
/* Google Fonts Import Link */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

*{
    font-family: 'Poppins', sans-serif;
}

.sidebar{
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    /* 展开时宽度为260px */
    width: 260px;
    background: #11101d;
    z-index: 100;
    transition: all .5s ease;
}

/* 关闭时宽度为78px */
.sidebar.close{
    width: 78px;
}


/* logo */
.sidebar .logo-details{
    height: 60px;
    width: 100%;
    display: flex;
    align-items: center;
}

.sidebar .logo-details i{
    font-size: 30px;
    color: #fff;
    height: 50px;
    /* 由于这里给了最小宽度，直接使logo在该范围进行居中 */
    min-width: 78px;
    /* 水平垂直居中 */
    text-align: center;
    line-height: 50px;
    transition: all .5s ease;
}

.sidebar.close .logo-details i{
    font-size: 45px;
}

.sidebar .logo-details .logo_name{
    font-size: 22px;
    color: #fff;
    font-weight: 600;
    transition: .3s ease;
    transition-delay: .1s;
}

.sidebar.close .logo-details .logo_name{
   transition-delay: 0s;
   opacity: 0;
   /* 定义元素是否对指针事件做出反应 */
   pointer-events: none;
}


/* 左侧栏 */
.sidebar .nav-links{
    height: 100%;
    padding: 25px 0 150px 0;
    overflow: auto;
}

.sidebar.close .nav-links{
    overflow: visible;
}

/* 滚动条不显示 */
.sidebar .nav-links::-webkit-scrollbar{
   display: none;
}

.sidebar .nav-links li{
    position: relative;
    transition: all .4s ease;
}

/* 悬停li的时候改变li颜色 */
.sidebar .nav-links li:hover{
    background: #1d1b31;
}

.sidebar .nav-links li .iocn-link{
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.sidebar.close .nav-links li .iocn-link{
    display: block;
}

.sidebar .nav-links li i{
    height: 50px;
    min-width: 78px;
    text-align: center;
    line-height: 50px;
    color: #fff;
    font-size: 20px;
    cursor: pointer;
    transition: all .3s ease;
}

.sidebar .nav-links li.showMenu i.arrow{
    /* 开关时箭头图标旋转变化 */
    transform: rotate(-180deg);
}

/* 关闭时箭头图标隐藏 */
.sidebar.close .nav-links i.arrow{
    display: none;
}

.sidebar .nav-links li a{
    /* 在li的宽高范围内水平垂直居中 */
    display: flex;
    align-items: center;
}

.sidebar.close .nav-links li a i{
    font-size: 30px;
}

.sidebar .nav-links li a .link_name{
    font-size: 18px;
    font-weight: 400;
    color: #fff;
    transition: all .4s ease;
}

.sidebar.close .nav-links li a .link_name{
    /* 这二个属性的作用相当于display:none;同时又对transition生效 */
    /* tips: display对transition不生效 */
    /* 透明隐藏 */
    opacity: 0;
    /* 关闭时去除点击效果，该属性可使该元素不会阻挡与之重叠的元素 */
    pointer-events: none;
}

.sidebar .nav-links li .sub-menu{
    padding: 6px 6px 14px 80px;
    background: #1d1b31;
    /* 默认不显示 */
    display: none;
}

.sidebar .nav-links li.showMenu .sub-menu{
    /* showMenu class有时显示二级菜单 */
    display: block;
}

.sidebar .nav-links li .sub-menu a{
    color: #fff;
    font-size: 15px;
    padding: 10px 0;
    white-space: nowrap;
    opacity: .6;
    transition: all .3s ease;
}

.sidebar .nav-links li .sub-menu a:hover{
    /* 二级菜单a链接显隐效果，通过透明度表达 */
    opacity: 1;
}

/* 关闭时二级菜谱的悬停效果 通过绝对定位制作*/
.sidebar.close .nav-links li .sub-menu{
    position: absolute;
    /* 距离右侧百分百 */
    left: 100%;
    /* 与一级菜单齐平 */
    top: -10;
    margin-top: 0;
    padding: 10px 20px;
    border-radius: 0 6px 6px 0;
    transition: 0s;
    opacity: 0;
    display: block;
    pointer-events: none;
}


/* 通过悬停li 触发关闭时二级菜单的显示隐藏 */
.sidebar.close .nav-links li:hover .sub-menu{
    /* 通过top的变动和transition来制作二级菜单出现时的动效 */
    top: 0;
    opacity: 1;
    pointer-events: auto;
    transition: all .4s ease;
}

.sidebar .nav-links li .sub-menu .link_name{
    display: none;
}

.sidebar.close .nav-links li .sub-menu .link_name{
    font-size: 18px;
    opacity: 1;
    display: block;
}

.sidebar .nav-links li .sub-menu.blank{
    opacity: 1;
    pointer-events: auto;
    padding: 3px 20px 6px 16px;
    /* 默认透明 */
    opacity: 0;
    pointer-events: none;
}

.sidebar.close .nav-links li:hover .sub-menu.blank{
    top: 50%;
    transform: translateY(-50%);
}


/* 个人信息 */
.sidebar .profile-details{
    width: 260px;
    /* fixed固定在底部 */
    position: fixed;
    bottom: 0;
    
    /* 常使用flex显示模式和其属性align-items做垂直居中*/
    display: flex;
    align-items: center;

    justify-content: space-between;
    background: #1d1b31;
    padding: 6px 0;
    transition: all .5s ease;
}

.sidebar.close .profile-details{
    /* 关闭时设置宽度 */
    width: 78px;
    /* 背景去除 */
    background: none;
}

.sidebar .profile-details .profile-content{
    /* 使用此垂直居中，关闭时也能适应 */
    display: flex;
    align-items: center;
}

.sidebar .profile-details .profile-content img{
    /* 图片元素固定是此宽高 */
    height: 52px;
    width: 52px;

    object-fit: cover;
    border-radius: 16px;
    margin: 0 14px 0 12px;
    background: #1d1b31;
    transition: all .5s ease;
}

.sidebar.close .profile-details .profile-content img{
    /* 关闭时通过给img元素添加padding来使图片达到变小的效果 */
    padding: 10px;
}

.sidebar .name-job .profile_name,
.sidebar .name-job .job{
    color: #fff;
    font-size: 18px;
    font-weight: 500;
    white-space: nowrap;
}

.sidebar .name-job .job{
    font-size: 12px;
}

/* 关闭时name-job和登出图标直接不显示 */
.sidebar.close .profile-details i,
.sidebar.close .name-job .profile_name,
.sidebar.close .name-job .job{
    display: none;
}

/* 处理头部右侧，无重要代码 */
.home-section{
    position: relative;
    height: 60px;
    /* 距离左侧的宽度 */
    left: 260px;
    /* 自身宽度使用calc计算得到 */
    width: calc(100% - 260px);
    background: #fff;
    transition: all .5s ease;
}

.sidebar.close ~ .home-section{
    /* 关闭时使其距左78px */
    left: 78px;
    /* 修改宽度 */
    width: calc(100% - 78px);
}

.home-section .home-content{
    height: 60px;
    display: flex;
    /* 垂直居中 */
    align-items: center;
}

.home-section .home-content .bx-menu,
.home-section .home-content .text{
    color: #11101d;
    font-size: 35px;
}

.home-section .home-content .bx-menu{
    margin: 0 15px;
    cursor: pointer;
}

.home-section .home-content .text{
    font-size: 26px;
    font-weight: 600;
}



